package com.bookrecomm.dao;

import com.bookrecomm.entity.MarketTrend;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Query;
import org.springframework.data.repository.query.Param;
import org.springframework.stereotype.Repository;

import java.time.LocalDate;
import java.util.List;

/**
 * 市场趋势数据访问接口
 */
@Repository
public interface MarketTrendRepository extends JpaRepository<MarketTrend, Long> {
    
    /**
     * 根据分类ID和日期范围查询市场趋势数据
     * @param categoryId 分类ID，如果为null则查询所有分类
     * @param startDate 开始日期
     * @param endDate 结束日期
     * @return 市场趋势数据列表
     */
    @Query("SELECT mt FROM MarketTrend mt " +
           "WHERE (:categoryId IS NULL OR mt.category.id = :categoryId) " +
           "AND mt.date BETWEEN :startDate AND :endDate " +
           "ORDER BY mt.date ASC")
    List<MarketTrend> findByCategoryAndDateRange(
            @Param("categoryId") Long categoryId,
            @Param("startDate") LocalDate startDate,
            @Param("endDate") LocalDate endDate);
}
